<html><body>
<style>

body, h1, h2, h3, div, span, p, pre, a {
  margin: 0;
  padding: 0;
  border: 0;
  font-weight: inherit;
  font-style: inherit;
  font-size: 100%;
  font-family: inherit;
  vertical-align: baseline;
}

body {
  font-size: 13px;
  padding: 1em;
}

h1 {
  font-size: 26px;
  margin-bottom: 1em;
}

h2 {
  font-size: 24px;
  margin-bottom: 1em;
}

h3 {
  font-size: 20px;
  margin-bottom: 1em;
  margin-top: 1em;
}

pre, code {
  line-height: 1.5;
  font-family: Monaco, 'DejaVu Sans Mono', 'Bitstream Vera Sans Mono', 'Lucida Console', monospace;
}

pre {
  margin-top: 0.5em;
}

h1, h2, h3, p {
  font-family: Arial, sans serif;
}

h1, h2, h3 {
  border-bottom: solid #CCC 1px;
}

.toc_element {
  margin-top: 0.5em;
}

.firstline {
  margin-left: 2 em;
}

.method  {
  margin-top: 1em;
  border: solid 1px #CCC;
  padding: 1em;
  background: #EEE;
}

.details {
  font-weight: bold;
  font-size: 14px;
}

</style>

<h1><a href="discoveryengine_v1alpha.html">Discovery Engine API</a> . <a href="discoveryengine_v1alpha.projects.html">projects</a> . <a href="discoveryengine_v1alpha.projects.locations.html">locations</a> . <a href="discoveryengine_v1alpha.projects.locations.collections.html">collections</a> . <a href="discoveryengine_v1alpha.projects.locations.collections.dataStores.html">dataStores</a> . <a href="discoveryengine_v1alpha.projects.locations.collections.dataStores.controls.html">controls</a></h1>
<h2>Instance Methods</h2>
<p class="toc_element">
  <code><a href="#close">close()</a></code></p>
<p class="firstline">Close httplib2 connections.</p>
<p class="toc_element">
  <code><a href="#create">create(parent, body=None, controlId=None, x__xgafv=None)</a></code></p>
<p class="firstline">Creates a Control. By default 1000 controls are allowed for a data store. A request can be submitted to adjust this limit. If the Control to create already exists, an ALREADY_EXISTS error is returned.</p>
<p class="toc_element">
  <code><a href="#delete">delete(name, x__xgafv=None)</a></code></p>
<p class="firstline">Deletes a Control. If the Control to delete does not exist, a NOT_FOUND error is returned.</p>
<p class="toc_element">
  <code><a href="#get">get(name, x__xgafv=None)</a></code></p>
<p class="firstline">Gets a Control.</p>
<p class="toc_element">
  <code><a href="#list">list(parent, filter=None, pageSize=None, pageToken=None, x__xgafv=None)</a></code></p>
<p class="firstline">Lists all Controls by their parent DataStore.</p>
<p class="toc_element">
  <code><a href="#list_next">list_next()</a></code></p>
<p class="firstline">Retrieves the next page of results.</p>
<p class="toc_element">
  <code><a href="#patch">patch(name, body=None, updateMask=None, x__xgafv=None)</a></code></p>
<p class="firstline">Updates a Control. Control action type cannot be changed. If the Control to update does not exist, a NOT_FOUND error is returned.</p>
<h3>Method Details</h3>
<div class="method">
    <code class="details" id="close">close()</code>
  <pre>Close httplib2 connections.</pre>
</div>

<div class="method">
    <code class="details" id="create">create(parent, body=None, controlId=None, x__xgafv=None)</code>
  <pre>Creates a Control. By default 1000 controls are allowed for a data store. A request can be submitted to adjust this limit. If the Control to create already exists, an ALREADY_EXISTS error is returned.

Args:
  parent: string, Required. Full resource name of parent data store. Format: `projects/{project}/locations/{location}/collections/{collection_id}/dataStores/{data_store_id}` or `projects/{project}/locations/{location}/collections/{collection_id}/engines/{engine_id}`. (required)
  body: object, The request body.
    The object takes the form of:

{ # Defines a conditioned behavior to employ during serving. Must be attached to a ServingConfig to be considered at serving time. Permitted actions dependent on `SolutionType`.
  &quot;associatedServingConfigIds&quot;: [ # Output only. List of all ServingConfig IDs this control is attached to. May take up to 10 minutes to update after changes.
    &quot;A String&quot;,
  ],
  &quot;boostAction&quot;: { # Adjusts order of products in returned list. # Defines a boost-type control
    &quot;boost&quot;: 3.14, # Strength of the boost, which should be in [-1, 1]. Negative boost means demotion. Default is 0.0 (No-op).
    &quot;dataStore&quot;: &quot;A String&quot;, # Required. Specifies which data store&#x27;s documents can be boosted by this control. Full data store name e.g. projects/123/locations/global/collections/default_collection/dataStores/default_data_store
    &quot;filter&quot;: &quot;A String&quot;, # Required. Specifies which products to apply the boost to. If no filter is provided all products will be boosted (No-op). Syntax documentation: https://cloud.google.com/retail/docs/filter-and-order Maximum length is 5000 characters. Otherwise an INVALID ARGUMENT error is thrown.
    &quot;fixedBoost&quot;: 3.14, # Optional. Strength of the boost, which should be in [-1, 1]. Negative boost means demotion. Default is 0.0 (No-op).
    &quot;interpolationBoostSpec&quot;: { # Specification for custom ranking based on customer specified attribute value. It provides more controls for customized ranking than the simple (condition, boost) combination above. # Optional. Complex specification for custom ranking based on customer defined attribute value.
      &quot;attributeType&quot;: &quot;A String&quot;, # Optional. The attribute type to be used to determine the boost amount. The attribute value can be derived from the field value of the specified field_name. In the case of numerical it is straightforward i.e. attribute_value = numerical_field_value. In the case of freshness however, attribute_value = (time.now() - datetime_field_value).
      &quot;controlPoints&quot;: [ # Optional. The control points used to define the curve. The monotonic function (defined through the interpolation_type above) passes through the control points listed here.
        { # The control points used to define the curve. The curve defined through these control points can only be monotonically increasing or decreasing(constant values are acceptable).
          &quot;attributeValue&quot;: &quot;A String&quot;, # Optional. Can be one of: 1. The numerical field value. 2. The duration spec for freshness: The value must be formatted as an XSD `dayTimeDuration` value (a restricted subset of an ISO 8601 duration value). The pattern for this is: `nDnM]`.
          &quot;boostAmount&quot;: 3.14, # Optional. The value between -1 to 1 by which to boost the score if the attribute_value evaluates to the value specified above.
        },
      ],
      &quot;fieldName&quot;: &quot;A String&quot;, # Optional. The name of the field whose value will be used to determine the boost amount.
      &quot;interpolationType&quot;: &quot;A String&quot;, # Optional. The interpolation type to be applied to connect the control points listed below.
    },
  },
  &quot;conditions&quot;: [ # Determines when the associated action will trigger. Omit to always apply the action. Currently only a single condition may be specified. Otherwise an INVALID ARGUMENT error is thrown.
    { # Defines circumstances to be checked before allowing a behavior
      &quot;activeTimeRange&quot;: [ # Range of time(s) specifying when condition is active. Maximum of 10 time ranges.
        { # Used for time-dependent conditions.
          &quot;endTime&quot;: &quot;A String&quot;, # End of time range. Range is inclusive. Must be in the future.
          &quot;startTime&quot;: &quot;A String&quot;, # Start of time range. Range is inclusive.
        },
      ],
      &quot;queryRegex&quot;: &quot;A String&quot;, # Optional. Query regex to match the whole search query. Cannot be set when Condition.query_terms is set. Only supported for Basic Site Search promotion serving controls.
      &quot;queryTerms&quot;: [ # Search only A list of terms to match the query on. Cannot be set when Condition.query_regex is set. Maximum of 10 query terms.
        { # Matcher for search request query
          &quot;fullMatch&quot;: True or False, # Whether the search query needs to exactly match the query term.
          &quot;value&quot;: &quot;A String&quot;, # The specific query value to match against Must be lowercase, must be UTF-8. Can have at most 3 space separated terms if full_match is true. Cannot be an empty string. Maximum length of 5000 characters.
        },
      ],
    },
  ],
  &quot;displayName&quot;: &quot;A String&quot;, # Required. Human readable name. The identifier used in UI views. Must be UTF-8 encoded string. Length limit is 128 characters. Otherwise an INVALID ARGUMENT error is thrown.
  &quot;filterAction&quot;: { # Specified which products may be included in results. Uses same filter as boost. # Defines a filter-type control Currently not supported by Recommendation
    &quot;dataStore&quot;: &quot;A String&quot;, # Required. Specifies which data store&#x27;s documents can be filtered by this control. Full data store name e.g. projects/123/locations/global/collections/default_collection/dataStores/default_data_store
    &quot;filter&quot;: &quot;A String&quot;, # Required. A filter to apply on the matching condition results. Required Syntax documentation: https://cloud.google.com/retail/docs/filter-and-order Maximum length is 5000 characters. Otherwise an INVALID ARGUMENT error is thrown.
  },
  &quot;name&quot;: &quot;A String&quot;, # Immutable. Fully qualified name `projects/*/locations/global/dataStore/*/controls/*`
  &quot;promoteAction&quot;: { # Promote certain links based on some trigger queries. Example: Promote shoe store link when searching for `shoe` keyword. The link can be outside of associated data store. # Promote certain links based on predefined trigger queries.
    &quot;dataStore&quot;: &quot;A String&quot;, # Required. Data store with which this promotion is attached to.
    &quot;searchLinkPromotion&quot;: { # Promotion proto includes uri and other helping information to display the promotion. # Required. Promotion attached to this action.
      &quot;description&quot;: &quot;A String&quot;, # Optional. The Promotion description. Maximum length: 200 characters.
      &quot;document&quot;: &quot;A String&quot;, # Optional. The Document the user wants to promote. For site search, leave unset and only populate uri. Can be set along with uri.
      &quot;enabled&quot;: True or False, # Optional. The enabled promotion will be returned for any serving configs associated with the parent of the control this promotion is attached to. This flag is used for basic site search only.
      &quot;imageUri&quot;: &quot;A String&quot;, # Optional. The promotion thumbnail image url.
      &quot;title&quot;: &quot;A String&quot;, # Required. The title of the promotion. Maximum length: 160 characters.
      &quot;uri&quot;: &quot;A String&quot;, # Optional. The URL for the page the user wants to promote. Must be set for site search. For other verticals, this is optional.
    },
  },
  &quot;redirectAction&quot;: { # Redirects a shopper to the provided URI. # Defines a redirect-type control.
    &quot;redirectUri&quot;: &quot;A String&quot;, # Required. The URI to which the shopper will be redirected. Required. URI must have length equal or less than 2000 characters. Otherwise an INVALID ARGUMENT error is thrown.
  },
  &quot;solutionType&quot;: &quot;A String&quot;, # Required. Immutable. What solution the control belongs to. Must be compatible with vertical of resource. Otherwise an INVALID ARGUMENT error is thrown.
  &quot;synonymsAction&quot;: { # Creates a set of terms that will act as synonyms of one another. Example: &quot;happy&quot; will also be considered as &quot;glad&quot;, &quot;glad&quot; will also be considered as &quot;happy&quot;. # Treats a group of terms as synonyms of one another.
    &quot;synonyms&quot;: [ # Defines a set of synonyms. Can specify up to 100 synonyms. Must specify at least 2 synonyms. Otherwise an INVALID ARGUMENT error is thrown.
      &quot;A String&quot;,
    ],
  },
  &quot;useCases&quot;: [ # Specifies the use case for the control. Affects what condition fields can be set. Only applies to SOLUTION_TYPE_SEARCH. Currently only allow one use case per control. Must be set when solution_type is SolutionType.SOLUTION_TYPE_SEARCH.
    &quot;A String&quot;,
  ],
}

  controlId: string, Required. The ID to use for the Control, which will become the final component of the Control&#x27;s resource name. This value must be within 1-63 characters. Valid characters are /a-z-_/.
  x__xgafv: string, V1 error format.
    Allowed values
      1 - v1 error format
      2 - v2 error format

Returns:
  An object of the form:

    { # Defines a conditioned behavior to employ during serving. Must be attached to a ServingConfig to be considered at serving time. Permitted actions dependent on `SolutionType`.
  &quot;associatedServingConfigIds&quot;: [ # Output only. List of all ServingConfig IDs this control is attached to. May take up to 10 minutes to update after changes.
    &quot;A String&quot;,
  ],
  &quot;boostAction&quot;: { # Adjusts order of products in returned list. # Defines a boost-type control
    &quot;boost&quot;: 3.14, # Strength of the boost, which should be in [-1, 1]. Negative boost means demotion. Default is 0.0 (No-op).
    &quot;dataStore&quot;: &quot;A String&quot;, # Required. Specifies which data store&#x27;s documents can be boosted by this control. Full data store name e.g. projects/123/locations/global/collections/default_collection/dataStores/default_data_store
    &quot;filter&quot;: &quot;A String&quot;, # Required. Specifies which products to apply the boost to. If no filter is provided all products will be boosted (No-op). Syntax documentation: https://cloud.google.com/retail/docs/filter-and-order Maximum length is 5000 characters. Otherwise an INVALID ARGUMENT error is thrown.
    &quot;fixedBoost&quot;: 3.14, # Optional. Strength of the boost, which should be in [-1, 1]. Negative boost means demotion. Default is 0.0 (No-op).
    &quot;interpolationBoostSpec&quot;: { # Specification for custom ranking based on customer specified attribute value. It provides more controls for customized ranking than the simple (condition, boost) combination above. # Optional. Complex specification for custom ranking based on customer defined attribute value.
      &quot;attributeType&quot;: &quot;A String&quot;, # Optional. The attribute type to be used to determine the boost amount. The attribute value can be derived from the field value of the specified field_name. In the case of numerical it is straightforward i.e. attribute_value = numerical_field_value. In the case of freshness however, attribute_value = (time.now() - datetime_field_value).
      &quot;controlPoints&quot;: [ # Optional. The control points used to define the curve. The monotonic function (defined through the interpolation_type above) passes through the control points listed here.
        { # The control points used to define the curve. The curve defined through these control points can only be monotonically increasing or decreasing(constant values are acceptable).
          &quot;attributeValue&quot;: &quot;A String&quot;, # Optional. Can be one of: 1. The numerical field value. 2. The duration spec for freshness: The value must be formatted as an XSD `dayTimeDuration` value (a restricted subset of an ISO 8601 duration value). The pattern for this is: `nDnM]`.
          &quot;boostAmount&quot;: 3.14, # Optional. The value between -1 to 1 by which to boost the score if the attribute_value evaluates to the value specified above.
        },
      ],
      &quot;fieldName&quot;: &quot;A String&quot;, # Optional. The name of the field whose value will be used to determine the boost amount.
      &quot;interpolationType&quot;: &quot;A String&quot;, # Optional. The interpolation type to be applied to connect the control points listed below.
    },
  },
  &quot;conditions&quot;: [ # Determines when the associated action will trigger. Omit to always apply the action. Currently only a single condition may be specified. Otherwise an INVALID ARGUMENT error is thrown.
    { # Defines circumstances to be checked before allowing a behavior
      &quot;activeTimeRange&quot;: [ # Range of time(s) specifying when condition is active. Maximum of 10 time ranges.
        { # Used for time-dependent conditions.
          &quot;endTime&quot;: &quot;A String&quot;, # End of time range. Range is inclusive. Must be in the future.
          &quot;startTime&quot;: &quot;A String&quot;, # Start of time range. Range is inclusive.
        },
      ],
      &quot;queryRegex&quot;: &quot;A String&quot;, # Optional. Query regex to match the whole search query. Cannot be set when Condition.query_terms is set. Only supported for Basic Site Search promotion serving controls.
      &quot;queryTerms&quot;: [ # Search only A list of terms to match the query on. Cannot be set when Condition.query_regex is set. Maximum of 10 query terms.
        { # Matcher for search request query
          &quot;fullMatch&quot;: True or False, # Whether the search query needs to exactly match the query term.
          &quot;value&quot;: &quot;A String&quot;, # The specific query value to match against Must be lowercase, must be UTF-8. Can have at most 3 space separated terms if full_match is true. Cannot be an empty string. Maximum length of 5000 characters.
        },
      ],
    },
  ],
  &quot;displayName&quot;: &quot;A String&quot;, # Required. Human readable name. The identifier used in UI views. Must be UTF-8 encoded string. Length limit is 128 characters. Otherwise an INVALID ARGUMENT error is thrown.
  &quot;filterAction&quot;: { # Specified which products may be included in results. Uses same filter as boost. # Defines a filter-type control Currently not supported by Recommendation
    &quot;dataStore&quot;: &quot;A String&quot;, # Required. Specifies which data store&#x27;s documents can be filtered by this control. Full data store name e.g. projects/123/locations/global/collections/default_collection/dataStores/default_data_store
    &quot;filter&quot;: &quot;A String&quot;, # Required. A filter to apply on the matching condition results. Required Syntax documentation: https://cloud.google.com/retail/docs/filter-and-order Maximum length is 5000 characters. Otherwise an INVALID ARGUMENT error is thrown.
  },
  &quot;name&quot;: &quot;A String&quot;, # Immutable. Fully qualified name `projects/*/locations/global/dataStore/*/controls/*`
  &quot;promoteAction&quot;: { # Promote certain links based on some trigger queries. Example: Promote shoe store link when searching for `shoe` keyword. The link can be outside of associated data store. # Promote certain links based on predefined trigger queries.
    &quot;dataStore&quot;: &quot;A String&quot;, # Required. Data store with which this promotion is attached to.
    &quot;searchLinkPromotion&quot;: { # Promotion proto includes uri and other helping information to display the promotion. # Required. Promotion attached to this action.
      &quot;description&quot;: &quot;A String&quot;, # Optional. The Promotion description. Maximum length: 200 characters.
      &quot;document&quot;: &quot;A String&quot;, # Optional. The Document the user wants to promote. For site search, leave unset and only populate uri. Can be set along with uri.
      &quot;enabled&quot;: True or False, # Optional. The enabled promotion will be returned for any serving configs associated with the parent of the control this promotion is attached to. This flag is used for basic site search only.
      &quot;imageUri&quot;: &quot;A String&quot;, # Optional. The promotion thumbnail image url.
      &quot;title&quot;: &quot;A String&quot;, # Required. The title of the promotion. Maximum length: 160 characters.
      &quot;uri&quot;: &quot;A String&quot;, # Optional. The URL for the page the user wants to promote. Must be set for site search. For other verticals, this is optional.
    },
  },
  &quot;redirectAction&quot;: { # Redirects a shopper to the provided URI. # Defines a redirect-type control.
    &quot;redirectUri&quot;: &quot;A String&quot;, # Required. The URI to which the shopper will be redirected. Required. URI must have length equal or less than 2000 characters. Otherwise an INVALID ARGUMENT error is thrown.
  },
  &quot;solutionType&quot;: &quot;A String&quot;, # Required. Immutable. What solution the control belongs to. Must be compatible with vertical of resource. Otherwise an INVALID ARGUMENT error is thrown.
  &quot;synonymsAction&quot;: { # Creates a set of terms that will act as synonyms of one another. Example: &quot;happy&quot; will also be considered as &quot;glad&quot;, &quot;glad&quot; will also be considered as &quot;happy&quot;. # Treats a group of terms as synonyms of one another.
    &quot;synonyms&quot;: [ # Defines a set of synonyms. Can specify up to 100 synonyms. Must specify at least 2 synonyms. Otherwise an INVALID ARGUMENT error is thrown.
      &quot;A String&quot;,
    ],
  },
  &quot;useCases&quot;: [ # Specifies the use case for the control. Affects what condition fields can be set. Only applies to SOLUTION_TYPE_SEARCH. Currently only allow one use case per control. Must be set when solution_type is SolutionType.SOLUTION_TYPE_SEARCH.
    &quot;A String&quot;,
  ],
}</pre>
</div>

<div class="method">
    <code class="details" id="delete">delete(name, x__xgafv=None)</code>
  <pre>Deletes a Control. If the Control to delete does not exist, a NOT_FOUND error is returned.

Args:
  name: string, Required. The resource name of the Control to delete. Format: `projects/{project}/locations/{location}/collections/{collection_id}/dataStores/{data_store_id}/controls/{control_id}` (required)
  x__xgafv: string, V1 error format.
    Allowed values
      1 - v1 error format
      2 - v2 error format

Returns:
  An object of the form:

    { # A generic empty message that you can re-use to avoid defining duplicated empty messages in your APIs. A typical example is to use it as the request or the response type of an API method. For instance: service Foo { rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty); }
}</pre>
</div>

<div class="method">
    <code class="details" id="get">get(name, x__xgafv=None)</code>
  <pre>Gets a Control.

Args:
  name: string, Required. The resource name of the Control to get. Format: `projects/{project}/locations/{location}/collections/{collection_id}/dataStores/{data_store_id}/controls/{control_id}` (required)
  x__xgafv: string, V1 error format.
    Allowed values
      1 - v1 error format
      2 - v2 error format

Returns:
  An object of the form:

    { # Defines a conditioned behavior to employ during serving. Must be attached to a ServingConfig to be considered at serving time. Permitted actions dependent on `SolutionType`.
  &quot;associatedServingConfigIds&quot;: [ # Output only. List of all ServingConfig IDs this control is attached to. May take up to 10 minutes to update after changes.
    &quot;A String&quot;,
  ],
  &quot;boostAction&quot;: { # Adjusts order of products in returned list. # Defines a boost-type control
    &quot;boost&quot;: 3.14, # Strength of the boost, which should be in [-1, 1]. Negative boost means demotion. Default is 0.0 (No-op).
    &quot;dataStore&quot;: &quot;A String&quot;, # Required. Specifies which data store&#x27;s documents can be boosted by this control. Full data store name e.g. projects/123/locations/global/collections/default_collection/dataStores/default_data_store
    &quot;filter&quot;: &quot;A String&quot;, # Required. Specifies which products to apply the boost to. If no filter is provided all products will be boosted (No-op). Syntax documentation: https://cloud.google.com/retail/docs/filter-and-order Maximum length is 5000 characters. Otherwise an INVALID ARGUMENT error is thrown.
    &quot;fixedBoost&quot;: 3.14, # Optional. Strength of the boost, which should be in [-1, 1]. Negative boost means demotion. Default is 0.0 (No-op).
    &quot;interpolationBoostSpec&quot;: { # Specification for custom ranking based on customer specified attribute value. It provides more controls for customized ranking than the simple (condition, boost) combination above. # Optional. Complex specification for custom ranking based on customer defined attribute value.
      &quot;attributeType&quot;: &quot;A String&quot;, # Optional. The attribute type to be used to determine the boost amount. The attribute value can be derived from the field value of the specified field_name. In the case of numerical it is straightforward i.e. attribute_value = numerical_field_value. In the case of freshness however, attribute_value = (time.now() - datetime_field_value).
      &quot;controlPoints&quot;: [ # Optional. The control points used to define the curve. The monotonic function (defined through the interpolation_type above) passes through the control points listed here.
        { # The control points used to define the curve. The curve defined through these control points can only be monotonically increasing or decreasing(constant values are acceptable).
          &quot;attributeValue&quot;: &quot;A String&quot;, # Optional. Can be one of: 1. The numerical field value. 2. The duration spec for freshness: The value must be formatted as an XSD `dayTimeDuration` value (a restricted subset of an ISO 8601 duration value). The pattern for this is: `nDnM]`.
          &quot;boostAmount&quot;: 3.14, # Optional. The value between -1 to 1 by which to boost the score if the attribute_value evaluates to the value specified above.
        },
      ],
      &quot;fieldName&quot;: &quot;A String&quot;, # Optional. The name of the field whose value will be used to determine the boost amount.
      &quot;interpolationType&quot;: &quot;A String&quot;, # Optional. The interpolation type to be applied to connect the control points listed below.
    },
  },
  &quot;conditions&quot;: [ # Determines when the associated action will trigger. Omit to always apply the action. Currently only a single condition may be specified. Otherwise an INVALID ARGUMENT error is thrown.
    { # Defines circumstances to be checked before allowing a behavior
      &quot;activeTimeRange&quot;: [ # Range of time(s) specifying when condition is active. Maximum of 10 time ranges.
        { # Used for time-dependent conditions.
          &quot;endTime&quot;: &quot;A String&quot;, # End of time range. Range is inclusive. Must be in the future.
          &quot;startTime&quot;: &quot;A String&quot;, # Start of time range. Range is inclusive.
        },
      ],
      &quot;queryRegex&quot;: &quot;A String&quot;, # Optional. Query regex to match the whole search query. Cannot be set when Condition.query_terms is set. Only supported for Basic Site Search promotion serving controls.
      &quot;queryTerms&quot;: [ # Search only A list of terms to match the query on. Cannot be set when Condition.query_regex is set. Maximum of 10 query terms.
        { # Matcher for search request query
          &quot;fullMatch&quot;: True or False, # Whether the search query needs to exactly match the query term.
          &quot;value&quot;: &quot;A String&quot;, # The specific query value to match against Must be lowercase, must be UTF-8. Can have at most 3 space separated terms if full_match is true. Cannot be an empty string. Maximum length of 5000 characters.
        },
      ],
    },
  ],
  &quot;displayName&quot;: &quot;A String&quot;, # Required. Human readable name. The identifier used in UI views. Must be UTF-8 encoded string. Length limit is 128 characters. Otherwise an INVALID ARGUMENT error is thrown.
  &quot;filterAction&quot;: { # Specified which products may be included in results. Uses same filter as boost. # Defines a filter-type control Currently not supported by Recommendation
    &quot;dataStore&quot;: &quot;A String&quot;, # Required. Specifies which data store&#x27;s documents can be filtered by this control. Full data store name e.g. projects/123/locations/global/collections/default_collection/dataStores/default_data_store
    &quot;filter&quot;: &quot;A String&quot;, # Required. A filter to apply on the matching condition results. Required Syntax documentation: https://cloud.google.com/retail/docs/filter-and-order Maximum length is 5000 characters. Otherwise an INVALID ARGUMENT error is thrown.
  },
  &quot;name&quot;: &quot;A String&quot;, # Immutable. Fully qualified name `projects/*/locations/global/dataStore/*/controls/*`
  &quot;promoteAction&quot;: { # Promote certain links based on some trigger queries. Example: Promote shoe store link when searching for `shoe` keyword. The link can be outside of associated data store. # Promote certain links based on predefined trigger queries.
    &quot;dataStore&quot;: &quot;A String&quot;, # Required. Data store with which this promotion is attached to.
    &quot;searchLinkPromotion&quot;: { # Promotion proto includes uri and other helping information to display the promotion. # Required. Promotion attached to this action.
      &quot;description&quot;: &quot;A String&quot;, # Optional. The Promotion description. Maximum length: 200 characters.
      &quot;document&quot;: &quot;A String&quot;, # Optional. The Document the user wants to promote. For site search, leave unset and only populate uri. Can be set along with uri.
      &quot;enabled&quot;: True or False, # Optional. The enabled promotion will be returned for any serving configs associated with the parent of the control this promotion is attached to. This flag is used for basic site search only.
      &quot;imageUri&quot;: &quot;A String&quot;, # Optional. The promotion thumbnail image url.
      &quot;title&quot;: &quot;A String&quot;, # Required. The title of the promotion. Maximum length: 160 characters.
      &quot;uri&quot;: &quot;A String&quot;, # Optional. The URL for the page the user wants to promote. Must be set for site search. For other verticals, this is optional.
    },
  },
  &quot;redirectAction&quot;: { # Redirects a shopper to the provided URI. # Defines a redirect-type control.
    &quot;redirectUri&quot;: &quot;A String&quot;, # Required. The URI to which the shopper will be redirected. Required. URI must have length equal or less than 2000 characters. Otherwise an INVALID ARGUMENT error is thrown.
  },
  &quot;solutionType&quot;: &quot;A String&quot;, # Required. Immutable. What solution the control belongs to. Must be compatible with vertical of resource. Otherwise an INVALID ARGUMENT error is thrown.
  &quot;synonymsAction&quot;: { # Creates a set of terms that will act as synonyms of one another. Example: &quot;happy&quot; will also be considered as &quot;glad&quot;, &quot;glad&quot; will also be considered as &quot;happy&quot;. # Treats a group of terms as synonyms of one another.
    &quot;synonyms&quot;: [ # Defines a set of synonyms. Can specify up to 100 synonyms. Must specify at least 2 synonyms. Otherwise an INVALID ARGUMENT error is thrown.
      &quot;A String&quot;,
    ],
  },
  &quot;useCases&quot;: [ # Specifies the use case for the control. Affects what condition fields can be set. Only applies to SOLUTION_TYPE_SEARCH. Currently only allow one use case per control. Must be set when solution_type is SolutionType.SOLUTION_TYPE_SEARCH.
    &quot;A String&quot;,
  ],
}</pre>
</div>

<div class="method">
    <code class="details" id="list">list(parent, filter=None, pageSize=None, pageToken=None, x__xgafv=None)</code>
  <pre>Lists all Controls by their parent DataStore.

Args:
  parent: string, Required. The data store resource name. Format: `projects/{project}/locations/{location}/collections/{collection_id}/dataStores/{data_store_id}` or `projects/{project}/locations/{location}/collections/{collection_id}/engines/{engine_id}`. (required)
  filter: string, Optional. A filter to apply on the list results. Supported features: * List all the products under the parent branch if filter is unset. Currently this field is unsupported.
  pageSize: integer, Optional. Maximum number of results to return. If unspecified, defaults to 50. Max allowed value is 1000.
  pageToken: string, Optional. A page token, received from a previous `ListControls` call. Provide this to retrieve the subsequent page.
  x__xgafv: string, V1 error format.
    Allowed values
      1 - v1 error format
      2 - v2 error format

Returns:
  An object of the form:

    { # Response for ListControls method.
  &quot;controls&quot;: [ # All the Controls for a given data store.
    { # Defines a conditioned behavior to employ during serving. Must be attached to a ServingConfig to be considered at serving time. Permitted actions dependent on `SolutionType`.
      &quot;associatedServingConfigIds&quot;: [ # Output only. List of all ServingConfig IDs this control is attached to. May take up to 10 minutes to update after changes.
        &quot;A String&quot;,
      ],
      &quot;boostAction&quot;: { # Adjusts order of products in returned list. # Defines a boost-type control
        &quot;boost&quot;: 3.14, # Strength of the boost, which should be in [-1, 1]. Negative boost means demotion. Default is 0.0 (No-op).
        &quot;dataStore&quot;: &quot;A String&quot;, # Required. Specifies which data store&#x27;s documents can be boosted by this control. Full data store name e.g. projects/123/locations/global/collections/default_collection/dataStores/default_data_store
        &quot;filter&quot;: &quot;A String&quot;, # Required. Specifies which products to apply the boost to. If no filter is provided all products will be boosted (No-op). Syntax documentation: https://cloud.google.com/retail/docs/filter-and-order Maximum length is 5000 characters. Otherwise an INVALID ARGUMENT error is thrown.
        &quot;fixedBoost&quot;: 3.14, # Optional. Strength of the boost, which should be in [-1, 1]. Negative boost means demotion. Default is 0.0 (No-op).
        &quot;interpolationBoostSpec&quot;: { # Specification for custom ranking based on customer specified attribute value. It provides more controls for customized ranking than the simple (condition, boost) combination above. # Optional. Complex specification for custom ranking based on customer defined attribute value.
          &quot;attributeType&quot;: &quot;A String&quot;, # Optional. The attribute type to be used to determine the boost amount. The attribute value can be derived from the field value of the specified field_name. In the case of numerical it is straightforward i.e. attribute_value = numerical_field_value. In the case of freshness however, attribute_value = (time.now() - datetime_field_value).
          &quot;controlPoints&quot;: [ # Optional. The control points used to define the curve. The monotonic function (defined through the interpolation_type above) passes through the control points listed here.
            { # The control points used to define the curve. The curve defined through these control points can only be monotonically increasing or decreasing(constant values are acceptable).
              &quot;attributeValue&quot;: &quot;A String&quot;, # Optional. Can be one of: 1. The numerical field value. 2. The duration spec for freshness: The value must be formatted as an XSD `dayTimeDuration` value (a restricted subset of an ISO 8601 duration value). The pattern for this is: `nDnM]`.
              &quot;boostAmount&quot;: 3.14, # Optional. The value between -1 to 1 by which to boost the score if the attribute_value evaluates to the value specified above.
            },
          ],
          &quot;fieldName&quot;: &quot;A String&quot;, # Optional. The name of the field whose value will be used to determine the boost amount.
          &quot;interpolationType&quot;: &quot;A String&quot;, # Optional. The interpolation type to be applied to connect the control points listed below.
        },
      },
      &quot;conditions&quot;: [ # Determines when the associated action will trigger. Omit to always apply the action. Currently only a single condition may be specified. Otherwise an INVALID ARGUMENT error is thrown.
        { # Defines circumstances to be checked before allowing a behavior
          &quot;activeTimeRange&quot;: [ # Range of time(s) specifying when condition is active. Maximum of 10 time ranges.
            { # Used for time-dependent conditions.
              &quot;endTime&quot;: &quot;A String&quot;, # End of time range. Range is inclusive. Must be in the future.
              &quot;startTime&quot;: &quot;A String&quot;, # Start of time range. Range is inclusive.
            },
          ],
          &quot;queryRegex&quot;: &quot;A String&quot;, # Optional. Query regex to match the whole search query. Cannot be set when Condition.query_terms is set. Only supported for Basic Site Search promotion serving controls.
          &quot;queryTerms&quot;: [ # Search only A list of terms to match the query on. Cannot be set when Condition.query_regex is set. Maximum of 10 query terms.
            { # Matcher for search request query
              &quot;fullMatch&quot;: True or False, # Whether the search query needs to exactly match the query term.
              &quot;value&quot;: &quot;A String&quot;, # The specific query value to match against Must be lowercase, must be UTF-8. Can have at most 3 space separated terms if full_match is true. Cannot be an empty string. Maximum length of 5000 characters.
            },
          ],
        },
      ],
      &quot;displayName&quot;: &quot;A String&quot;, # Required. Human readable name. The identifier used in UI views. Must be UTF-8 encoded string. Length limit is 128 characters. Otherwise an INVALID ARGUMENT error is thrown.
      &quot;filterAction&quot;: { # Specified which products may be included in results. Uses same filter as boost. # Defines a filter-type control Currently not supported by Recommendation
        &quot;dataStore&quot;: &quot;A String&quot;, # Required. Specifies which data store&#x27;s documents can be filtered by this control. Full data store name e.g. projects/123/locations/global/collections/default_collection/dataStores/default_data_store
        &quot;filter&quot;: &quot;A String&quot;, # Required. A filter to apply on the matching condition results. Required Syntax documentation: https://cloud.google.com/retail/docs/filter-and-order Maximum length is 5000 characters. Otherwise an INVALID ARGUMENT error is thrown.
      },
      &quot;name&quot;: &quot;A String&quot;, # Immutable. Fully qualified name `projects/*/locations/global/dataStore/*/controls/*`
      &quot;promoteAction&quot;: { # Promote certain links based on some trigger queries. Example: Promote shoe store link when searching for `shoe` keyword. The link can be outside of associated data store. # Promote certain links based on predefined trigger queries.
        &quot;dataStore&quot;: &quot;A String&quot;, # Required. Data store with which this promotion is attached to.
        &quot;searchLinkPromotion&quot;: { # Promotion proto includes uri and other helping information to display the promotion. # Required. Promotion attached to this action.
          &quot;description&quot;: &quot;A String&quot;, # Optional. The Promotion description. Maximum length: 200 characters.
          &quot;document&quot;: &quot;A String&quot;, # Optional. The Document the user wants to promote. For site search, leave unset and only populate uri. Can be set along with uri.
          &quot;enabled&quot;: True or False, # Optional. The enabled promotion will be returned for any serving configs associated with the parent of the control this promotion is attached to. This flag is used for basic site search only.
          &quot;imageUri&quot;: &quot;A String&quot;, # Optional. The promotion thumbnail image url.
          &quot;title&quot;: &quot;A String&quot;, # Required. The title of the promotion. Maximum length: 160 characters.
          &quot;uri&quot;: &quot;A String&quot;, # Optional. The URL for the page the user wants to promote. Must be set for site search. For other verticals, this is optional.
        },
      },
      &quot;redirectAction&quot;: { # Redirects a shopper to the provided URI. # Defines a redirect-type control.
        &quot;redirectUri&quot;: &quot;A String&quot;, # Required. The URI to which the shopper will be redirected. Required. URI must have length equal or less than 2000 characters. Otherwise an INVALID ARGUMENT error is thrown.
      },
      &quot;solutionType&quot;: &quot;A String&quot;, # Required. Immutable. What solution the control belongs to. Must be compatible with vertical of resource. Otherwise an INVALID ARGUMENT error is thrown.
      &quot;synonymsAction&quot;: { # Creates a set of terms that will act as synonyms of one another. Example: &quot;happy&quot; will also be considered as &quot;glad&quot;, &quot;glad&quot; will also be considered as &quot;happy&quot;. # Treats a group of terms as synonyms of one another.
        &quot;synonyms&quot;: [ # Defines a set of synonyms. Can specify up to 100 synonyms. Must specify at least 2 synonyms. Otherwise an INVALID ARGUMENT error is thrown.
          &quot;A String&quot;,
        ],
      },
      &quot;useCases&quot;: [ # Specifies the use case for the control. Affects what condition fields can be set. Only applies to SOLUTION_TYPE_SEARCH. Currently only allow one use case per control. Must be set when solution_type is SolutionType.SOLUTION_TYPE_SEARCH.
        &quot;A String&quot;,
      ],
    },
  ],
  &quot;nextPageToken&quot;: &quot;A String&quot;, # Pagination token, if not returned indicates the last page.
}</pre>
</div>

<div class="method">
    <code class="details" id="list_next">list_next()</code>
  <pre>Retrieves the next page of results.

        Args:
          previous_request: The request for the previous page. (required)
          previous_response: The response from the request for the previous page. (required)

        Returns:
          A request object that you can call &#x27;execute()&#x27; on to request the next
          page. Returns None if there are no more items in the collection.
        </pre>
</div>

<div class="method">
    <code class="details" id="patch">patch(name, body=None, updateMask=None, x__xgafv=None)</code>
  <pre>Updates a Control. Control action type cannot be changed. If the Control to update does not exist, a NOT_FOUND error is returned.

Args:
  name: string, Immutable. Fully qualified name `projects/*/locations/global/dataStore/*/controls/*` (required)
  body: object, The request body.
    The object takes the form of:

{ # Defines a conditioned behavior to employ during serving. Must be attached to a ServingConfig to be considered at serving time. Permitted actions dependent on `SolutionType`.
  &quot;associatedServingConfigIds&quot;: [ # Output only. List of all ServingConfig IDs this control is attached to. May take up to 10 minutes to update after changes.
    &quot;A String&quot;,
  ],
  &quot;boostAction&quot;: { # Adjusts order of products in returned list. # Defines a boost-type control
    &quot;boost&quot;: 3.14, # Strength of the boost, which should be in [-1, 1]. Negative boost means demotion. Default is 0.0 (No-op).
    &quot;dataStore&quot;: &quot;A String&quot;, # Required. Specifies which data store&#x27;s documents can be boosted by this control. Full data store name e.g. projects/123/locations/global/collections/default_collection/dataStores/default_data_store
    &quot;filter&quot;: &quot;A String&quot;, # Required. Specifies which products to apply the boost to. If no filter is provided all products will be boosted (No-op). Syntax documentation: https://cloud.google.com/retail/docs/filter-and-order Maximum length is 5000 characters. Otherwise an INVALID ARGUMENT error is thrown.
    &quot;fixedBoost&quot;: 3.14, # Optional. Strength of the boost, which should be in [-1, 1]. Negative boost means demotion. Default is 0.0 (No-op).
    &quot;interpolationBoostSpec&quot;: { # Specification for custom ranking based on customer specified attribute value. It provides more controls for customized ranking than the simple (condition, boost) combination above. # Optional. Complex specification for custom ranking based on customer defined attribute value.
      &quot;attributeType&quot;: &quot;A String&quot;, # Optional. The attribute type to be used to determine the boost amount. The attribute value can be derived from the field value of the specified field_name. In the case of numerical it is straightforward i.e. attribute_value = numerical_field_value. In the case of freshness however, attribute_value = (time.now() - datetime_field_value).
      &quot;controlPoints&quot;: [ # Optional. The control points used to define the curve. The monotonic function (defined through the interpolation_type above) passes through the control points listed here.
        { # The control points used to define the curve. The curve defined through these control points can only be monotonically increasing or decreasing(constant values are acceptable).
          &quot;attributeValue&quot;: &quot;A String&quot;, # Optional. Can be one of: 1. The numerical field value. 2. The duration spec for freshness: The value must be formatted as an XSD `dayTimeDuration` value (a restricted subset of an ISO 8601 duration value). The pattern for this is: `nDnM]`.
          &quot;boostAmount&quot;: 3.14, # Optional. The value between -1 to 1 by which to boost the score if the attribute_value evaluates to the value specified above.
        },
      ],
      &quot;fieldName&quot;: &quot;A String&quot;, # Optional. The name of the field whose value will be used to determine the boost amount.
      &quot;interpolationType&quot;: &quot;A String&quot;, # Optional. The interpolation type to be applied to connect the control points listed below.
    },
  },
  &quot;conditions&quot;: [ # Determines when the associated action will trigger. Omit to always apply the action. Currently only a single condition may be specified. Otherwise an INVALID ARGUMENT error is thrown.
    { # Defines circumstances to be checked before allowing a behavior
      &quot;activeTimeRange&quot;: [ # Range of time(s) specifying when condition is active. Maximum of 10 time ranges.
        { # Used for time-dependent conditions.
          &quot;endTime&quot;: &quot;A String&quot;, # End of time range. Range is inclusive. Must be in the future.
          &quot;startTime&quot;: &quot;A String&quot;, # Start of time range. Range is inclusive.
        },
      ],
      &quot;queryRegex&quot;: &quot;A String&quot;, # Optional. Query regex to match the whole search query. Cannot be set when Condition.query_terms is set. Only supported for Basic Site Search promotion serving controls.
      &quot;queryTerms&quot;: [ # Search only A list of terms to match the query on. Cannot be set when Condition.query_regex is set. Maximum of 10 query terms.
        { # Matcher for search request query
          &quot;fullMatch&quot;: True or False, # Whether the search query needs to exactly match the query term.
          &quot;value&quot;: &quot;A String&quot;, # The specific query value to match against Must be lowercase, must be UTF-8. Can have at most 3 space separated terms if full_match is true. Cannot be an empty string. Maximum length of 5000 characters.
        },
      ],
    },
  ],
  &quot;displayName&quot;: &quot;A String&quot;, # Required. Human readable name. The identifier used in UI views. Must be UTF-8 encoded string. Length limit is 128 characters. Otherwise an INVALID ARGUMENT error is thrown.
  &quot;filterAction&quot;: { # Specified which products may be included in results. Uses same filter as boost. # Defines a filter-type control Currently not supported by Recommendation
    &quot;dataStore&quot;: &quot;A String&quot;, # Required. Specifies which data store&#x27;s documents can be filtered by this control. Full data store name e.g. projects/123/locations/global/collections/default_collection/dataStores/default_data_store
    &quot;filter&quot;: &quot;A String&quot;, # Required. A filter to apply on the matching condition results. Required Syntax documentation: https://cloud.google.com/retail/docs/filter-and-order Maximum length is 5000 characters. Otherwise an INVALID ARGUMENT error is thrown.
  },
  &quot;name&quot;: &quot;A String&quot;, # Immutable. Fully qualified name `projects/*/locations/global/dataStore/*/controls/*`
  &quot;promoteAction&quot;: { # Promote certain links based on some trigger queries. Example: Promote shoe store link when searching for `shoe` keyword. The link can be outside of associated data store. # Promote certain links based on predefined trigger queries.
    &quot;dataStore&quot;: &quot;A String&quot;, # Required. Data store with which this promotion is attached to.
    &quot;searchLinkPromotion&quot;: { # Promotion proto includes uri and other helping information to display the promotion. # Required. Promotion attached to this action.
      &quot;description&quot;: &quot;A String&quot;, # Optional. The Promotion description. Maximum length: 200 characters.
      &quot;document&quot;: &quot;A String&quot;, # Optional. The Document the user wants to promote. For site search, leave unset and only populate uri. Can be set along with uri.
      &quot;enabled&quot;: True or False, # Optional. The enabled promotion will be returned for any serving configs associated with the parent of the control this promotion is attached to. This flag is used for basic site search only.
      &quot;imageUri&quot;: &quot;A String&quot;, # Optional. The promotion thumbnail image url.
      &quot;title&quot;: &quot;A String&quot;, # Required. The title of the promotion. Maximum length: 160 characters.
      &quot;uri&quot;: &quot;A String&quot;, # Optional. The URL for the page the user wants to promote. Must be set for site search. For other verticals, this is optional.
    },
  },
  &quot;redirectAction&quot;: { # Redirects a shopper to the provided URI. # Defines a redirect-type control.
    &quot;redirectUri&quot;: &quot;A String&quot;, # Required. The URI to which the shopper will be redirected. Required. URI must have length equal or less than 2000 characters. Otherwise an INVALID ARGUMENT error is thrown.
  },
  &quot;solutionType&quot;: &quot;A String&quot;, # Required. Immutable. What solution the control belongs to. Must be compatible with vertical of resource. Otherwise an INVALID ARGUMENT error is thrown.
  &quot;synonymsAction&quot;: { # Creates a set of terms that will act as synonyms of one another. Example: &quot;happy&quot; will also be considered as &quot;glad&quot;, &quot;glad&quot; will also be considered as &quot;happy&quot;. # Treats a group of terms as synonyms of one another.
    &quot;synonyms&quot;: [ # Defines a set of synonyms. Can specify up to 100 synonyms. Must specify at least 2 synonyms. Otherwise an INVALID ARGUMENT error is thrown.
      &quot;A String&quot;,
    ],
  },
  &quot;useCases&quot;: [ # Specifies the use case for the control. Affects what condition fields can be set. Only applies to SOLUTION_TYPE_SEARCH. Currently only allow one use case per control. Must be set when solution_type is SolutionType.SOLUTION_TYPE_SEARCH.
    &quot;A String&quot;,
  ],
}

  updateMask: string, Optional. Indicates which fields in the provided Control to update. The following are NOT supported: * Control.name * Control.solution_type If not set or empty, all supported fields are updated.
  x__xgafv: string, V1 error format.
    Allowed values
      1 - v1 error format
      2 - v2 error format

Returns:
  An object of the form:

    { # Defines a conditioned behavior to employ during serving. Must be attached to a ServingConfig to be considered at serving time. Permitted actions dependent on `SolutionType`.
  &quot;associatedServingConfigIds&quot;: [ # Output only. List of all ServingConfig IDs this control is attached to. May take up to 10 minutes to update after changes.
    &quot;A String&quot;,
  ],
  &quot;boostAction&quot;: { # Adjusts order of products in returned list. # Defines a boost-type control
    &quot;boost&quot;: 3.14, # Strength of the boost, which should be in [-1, 1]. Negative boost means demotion. Default is 0.0 (No-op).
    &quot;dataStore&quot;: &quot;A String&quot;, # Required. Specifies which data store&#x27;s documents can be boosted by this control. Full data store name e.g. projects/123/locations/global/collections/default_collection/dataStores/default_data_store
    &quot;filter&quot;: &quot;A String&quot;, # Required. Specifies which products to apply the boost to. If no filter is provided all products will be boosted (No-op). Syntax documentation: https://cloud.google.com/retail/docs/filter-and-order Maximum length is 5000 characters. Otherwise an INVALID ARGUMENT error is thrown.
    &quot;fixedBoost&quot;: 3.14, # Optional. Strength of the boost, which should be in [-1, 1]. Negative boost means demotion. Default is 0.0 (No-op).
    &quot;interpolationBoostSpec&quot;: { # Specification for custom ranking based on customer specified attribute value. It provides more controls for customized ranking than the simple (condition, boost) combination above. # Optional. Complex specification for custom ranking based on customer defined attribute value.
      &quot;attributeType&quot;: &quot;A String&quot;, # Optional. The attribute type to be used to determine the boost amount. The attribute value can be derived from the field value of the specified field_name. In the case of numerical it is straightforward i.e. attribute_value = numerical_field_value. In the case of freshness however, attribute_value = (time.now() - datetime_field_value).
      &quot;controlPoints&quot;: [ # Optional. The control points used to define the curve. The monotonic function (defined through the interpolation_type above) passes through the control points listed here.
        { # The control points used to define the curve. The curve defined through these control points can only be monotonically increasing or decreasing(constant values are acceptable).
          &quot;attributeValue&quot;: &quot;A String&quot;, # Optional. Can be one of: 1. The numerical field value. 2. The duration spec for freshness: The value must be formatted as an XSD `dayTimeDuration` value (a restricted subset of an ISO 8601 duration value). The pattern for this is: `nDnM]`.
          &quot;boostAmount&quot;: 3.14, # Optional. The value between -1 to 1 by which to boost the score if the attribute_value evaluates to the value specified above.
        },
      ],
      &quot;fieldName&quot;: &quot;A String&quot;, # Optional. The name of the field whose value will be used to determine the boost amount.
      &quot;interpolationType&quot;: &quot;A String&quot;, # Optional. The interpolation type to be applied to connect the control points listed below.
    },
  },
  &quot;conditions&quot;: [ # Determines when the associated action will trigger. Omit to always apply the action. Currently only a single condition may be specified. Otherwise an INVALID ARGUMENT error is thrown.
    { # Defines circumstances to be checked before allowing a behavior
      &quot;activeTimeRange&quot;: [ # Range of time(s) specifying when condition is active. Maximum of 10 time ranges.
        { # Used for time-dependent conditions.
          &quot;endTime&quot;: &quot;A String&quot;, # End of time range. Range is inclusive. Must be in the future.
          &quot;startTime&quot;: &quot;A String&quot;, # Start of time range. Range is inclusive.
        },
      ],
      &quot;queryRegex&quot;: &quot;A String&quot;, # Optional. Query regex to match the whole search query. Cannot be set when Condition.query_terms is set. Only supported for Basic Site Search promotion serving controls.
      &quot;queryTerms&quot;: [ # Search only A list of terms to match the query on. Cannot be set when Condition.query_regex is set. Maximum of 10 query terms.
        { # Matcher for search request query
          &quot;fullMatch&quot;: True or False, # Whether the search query needs to exactly match the query term.
          &quot;value&quot;: &quot;A String&quot;, # The specific query value to match against Must be lowercase, must be UTF-8. Can have at most 3 space separated terms if full_match is true. Cannot be an empty string. Maximum length of 5000 characters.
        },
      ],
    },
  ],
  &quot;displayName&quot;: &quot;A String&quot;, # Required. Human readable name. The identifier used in UI views. Must be UTF-8 encoded string. Length limit is 128 characters. Otherwise an INVALID ARGUMENT error is thrown.
  &quot;filterAction&quot;: { # Specified which products may be included in results. Uses same filter as boost. # Defines a filter-type control Currently not supported by Recommendation
    &quot;dataStore&quot;: &quot;A String&quot;, # Required. Specifies which data store&#x27;s documents can be filtered by this control. Full data store name e.g. projects/123/locations/global/collections/default_collection/dataStores/default_data_store
    &quot;filter&quot;: &quot;A String&quot;, # Required. A filter to apply on the matching condition results. Required Syntax documentation: https://cloud.google.com/retail/docs/filter-and-order Maximum length is 5000 characters. Otherwise an INVALID ARGUMENT error is thrown.
  },
  &quot;name&quot;: &quot;A String&quot;, # Immutable. Fully qualified name `projects/*/locations/global/dataStore/*/controls/*`
  &quot;promoteAction&quot;: { # Promote certain links based on some trigger queries. Example: Promote shoe store link when searching for `shoe` keyword. The link can be outside of associated data store. # Promote certain links based on predefined trigger queries.
    &quot;dataStore&quot;: &quot;A String&quot;, # Required. Data store with which this promotion is attached to.
    &quot;searchLinkPromotion&quot;: { # Promotion proto includes uri and other helping information to display the promotion. # Required. Promotion attached to this action.
      &quot;description&quot;: &quot;A String&quot;, # Optional. The Promotion description. Maximum length: 200 characters.
      &quot;document&quot;: &quot;A String&quot;, # Optional. The Document the user wants to promote. For site search, leave unset and only populate uri. Can be set along with uri.
      &quot;enabled&quot;: True or False, # Optional. The enabled promotion will be returned for any serving configs associated with the parent of the control this promotion is attached to. This flag is used for basic site search only.
      &quot;imageUri&quot;: &quot;A String&quot;, # Optional. The promotion thumbnail image url.
      &quot;title&quot;: &quot;A String&quot;, # Required. The title of the promotion. Maximum length: 160 characters.
      &quot;uri&quot;: &quot;A String&quot;, # Optional. The URL for the page the user wants to promote. Must be set for site search. For other verticals, this is optional.
    },
  },
  &quot;redirectAction&quot;: { # Redirects a shopper to the provided URI. # Defines a redirect-type control.
    &quot;redirectUri&quot;: &quot;A String&quot;, # Required. The URI to which the shopper will be redirected. Required. URI must have length equal or less than 2000 characters. Otherwise an INVALID ARGUMENT error is thrown.
  },
  &quot;solutionType&quot;: &quot;A String&quot;, # Required. Immutable. What solution the control belongs to. Must be compatible with vertical of resource. Otherwise an INVALID ARGUMENT error is thrown.
  &quot;synonymsAction&quot;: { # Creates a set of terms that will act as synonyms of one another. Example: &quot;happy&quot; will also be considered as &quot;glad&quot;, &quot;glad&quot; will also be considered as &quot;happy&quot;. # Treats a group of terms as synonyms of one another.
    &quot;synonyms&quot;: [ # Defines a set of synonyms. Can specify up to 100 synonyms. Must specify at least 2 synonyms. Otherwise an INVALID ARGUMENT error is thrown.
      &quot;A String&quot;,
    ],
  },
  &quot;useCases&quot;: [ # Specifies the use case for the control. Affects what condition fields can be set. Only applies to SOLUTION_TYPE_SEARCH. Currently only allow one use case per control. Must be set when solution_type is SolutionType.SOLUTION_TYPE_SEARCH.
    &quot;A String&quot;,
  ],
}</pre>
</div>

</body></html>